#include <cstdio>
#include <cstring>
#define MAXN 101
char s[MAXN], in[MAXN];
// []重新写
int main()
{
    int n;
    scanf("%d\n%s", &n, s);
    for (int i = 1; i <= n; i++)
    {
        int opt;
        scanf("%d", &opt);
        if (opt == 1)
        {
            scanf("%s", in);
            strcat(s, in);
            printf("%s\n", s);
        }
        else if (opt == 2)
        {
            int a, b;
            scanf("%d %d", &a, &b);
            s[a + b] = '\0';
            strcpy(in, &s[a]);
            strcpy(s, in);
            printf("%s\n", s);
        }
        else if (opt == 3)
        {
            int a;
            scanf("%d %s", &a, in);
            strcat(in, &s[a]);
            s[a] = '\0';
            strcat(s, in);
            printf("%s\n", s);
        }
        else if (opt == 4)
        {
            scanf("%s", in);
            char *ans = strstr(s, in);
            if (ans != NULL)
            {
                printf("%d\n", int(ans - s));
            }
            else
            {
                printf("%d\n", -1);
            }
        }
    }
    return 0;
}
/*
https://www.luogu.com.cn/problem/solution/P5734
#include<cstdio>
#include<cstring>
#define MAXN 101
char s[MAXN],in[MAXN];
int main()
{
    int n;
    scanf("%d\n%s",&n,s);
    for(int i=1;i<=n;i++){
        int opt;
        scanf("%d",&opt);
        if(opt==1){
            scanf("%s",in);
            strcat(s,in);
            printf("%s\n",s);
        }else if(opt==2){
            int a,b;
            scanf("%d %d",&a,&b);
            s[a+b]='\0';
            strcpy(in,&s[a]);
            strcpy(s,in);
            printf("%s\n",s);
        }else if(opt==3){
            int a;
            scanf("%d %s",&a,in);
            strcat(in,&s[a]);
            s[a]='\0';
            strcat(s,in);
            printf("%s\n",s);
        }else if(opt==4){
            scanf("%s",in);
            char*ans=strstr(s,in);
            if(ans!=NULL){
                printf("%d\n",int(ans-s));
            }else{
                printf("%d\n",-1);
            }
        }
    }
    return 0;
}
*/

/*
题目描述
你需要开发一款文字处理软件。最开始时输入一个字符串（不超过 100 个字符）作为初始文档。可以认为文档开头是第 0 个字符。需要支持以下操作：

1 str：后接插入，在文档后面插入字符串 str，并输出文档的字符串。

2 a b：截取文档部分，只保留文档中从第 a 个字符起 b 个字符，并输出文档的字符串。

3 a str：插入片段，在文档中第 a 个字符前面插入字符串 str，并输出文档的字符串。

4 str：查找子串，查找字符串 str 在文档中最先的位置并输出；如果找不到输出 -1。

为了简化问题，规定初始的文档和每次操作中的 str 都不含有空格或换行。最多会有 q(q\le100)q(q≤100) 次操作。

输入格式
无

输出格式
无

输入输出样例
输入 #1复制
4
ILove
1 Luogu
2 5 5
3 3 guGugu
4 gu
输出 #1复制
ILoveLuogu
Luogu
LuoguGugugu
3
*/